package com.sojson.project.sys.role.dao;

import java.util.List;
import java.util.Set;

import com.baomidou.mybatisplus.core.mapper.BaseMapper;
import com.sojson.project.sys.role.entity.dto.UserRoleDto;
import com.sojson.project.sys.role.entity.dto.UserRolePageDto;
import com.sojson.project.sys.role.entity.po.UserRole;
import com.sojson.project.sys.role.entity.vo.UserRoleVo;

/**
 * 用户和角色关联表Dao
 * 
 * @author liu
 * @date 2021-04-15
 */
public interface UserRoleDao extends BaseMapper<UserRole> {

    /**
     * 通过对象查找
     * 
     * @param dto
     * @return
     */
    List<UserRoleVo> list(UserRoleDto dto);

    /**
     * 通过对象分页查找
     * 
     * @param dto
     * @return
     */
    List<UserRoleVo> page(UserRolePageDto dto);

    /**
     * 通过对象删除
     * 
     * @param dto
     * @return
     */
    int removeByDto(UserRoleDto dto);

    /**
     * 清空数据
     * 
     * @return
     */
    int clear();

    /**
     * 通过角色ID集合查询角色使用数量
     *
     * @param userTableNames    用户表名集合
     * @param roleIds           角色ID集合
     * @return 结果
     */
    int countUserRoleByRoleIds(List<String> userTableNames, Set<String> roleIds);

    /**
     * 通过用户ID数组删除
     * 
     * @param ids
     * @return
     */
    int deleteByUserIds(Set<String> ids);

    /**
     * 通过角色ID数组删除
     * 
     * @param ids
     * @return
     */
    int deleteByRoleIds(Set<String> ids);

}